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Bus system 



This invention relates to a bus system, and in particular to a bus controller, and 
to a device incorporating the bus controller. 

More particularly, the invention relates to an integrated circuit which can be 
used as a host controller within an electronic device, in order to improve the efficiency of 
5 operation of the device. 

In a conventional electronic device, operating as a USB host, the processor is 
able to write data into a system memory. A host controller integrated circuit is then able to 
■ read the data directly firom the system memory. In order to be able to do this, the host 
controller needs to master the system memory. However, since the system memory is shared 
10 between the host controller integrated circuit and the system processor, this requirement that 
the host controller be able to master the system memory requires &e use of a bus master, 
which is specific to the system processor. Moreover, while the host controller is mastering 
the system memory, the core fimction of the device, running under the control of the system 
processor, maybe disrupted. 
1 5 According to an aspect of the present invention, a host controller integrated 

circuit is unable to master the system memory, but instead acts purely as a slave. The 
embedded processor is then adapted to write the data to the host controller integrated circuit 
in die form of transfer-based transactions. 

20 

Fig. I IS a block schematic diagram of a USB host in accordance with an 
aspect of the present invention. 

Fig. 2 is a block schematic diagram of a host controller in accordance with 
another aspect of the invention. 
25 Fig. 3 is a block schematic diagram of an alternative form of host controller in 

accordance with an aspect of the invention. 

Fig. 4 illustrates the structure of the memory in the host controller of Fig. 2 or 

Fig. 3. 

Fig. 5 is an illustration showing the format of software in the device of Fig. 1. 
CONFIRKWION COPY 
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Fig. 6 illustrates the format of data written from the host microprocessor to the 
host controller. 

Fig. 7 shows the structure of a transfer descriptor header, with which data is 

transferred. 

Fig. 8 is a schematic representation of data to be transmitted, stored in the 
memory of Fig. 4. 

Fif . 9 illustrates a method by which the data of Fig. 8 may be transmitted. 



Fig. 1 is a block schematic diagram of die relevant parts of an electronic 
device 10, operating as a USB host. The invention is particularly applicable to devices such 
as mobile phones, or PDAs, in which the functional limitations of the microprocessor and the 
system memory are more relevant, rather than in personal computers (PCs). However, the 
invention is appUcable to any device which can operate as a USB host. 

It will be apparent that the device 1 0 will have many features, which are not 
shown in Fig. 1, since they are not relevant to an understanding of the present invwition. 

The device 10 has a host microprocessor 20, which includes a processor core 
22, connected by a standard system bus 23 to a LCD controller 24, a DMA master 25, and a 
memory controller 26. The memory controller 26 is connected to a system memory 30 by 
means of a peripheral bus 32. 

A host controller 40 is also connected to the host microprocessor 20 and the 
system memory 30, by means of the peripheral bus, or memory bus, 32. The host controller 
40 has an interface for a USB bus 42, through which it can be connected to multiple USB 
devices. In this illustrated embodiment, the host controller 40 is a USB 2.0 host controller. 

As is convmtional, the host controller 40 is adapted to retrieve data which is 
prepared by the processor 20 in a suitable format, and to transmit the data over the bus 
interface. In USB communications, there are two categories of data transfer, namely 
asynchronous transfer and periodic transfer. Control and bulk data are transmitted using 
asynchronous transfer, and ISO and interrupt data are transmitted using periodic transfer. A 
Queue Transaction Descriptor (qTD) data strurture is used for asynchronous transfer, and an 
Isochronous Transaction Descriptor (iTD) data structure is used for periodic transfer. 

The processor 20 prepares the data in the appropriate structure, and stores it in 
the system memory 30, and the host controller 40 must then retrieve the data from the system 
memory 30. 
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Fig. 2 shows in more detail the structure of the embedded USB host 

controller 40. 

As mentioned above, the host controller 40 has a connection for the memory 
bus 32, which is connected to an interface 44, containing a Memory Mapped Input/Output, a 
Memory Management Unit, and a Slave DMA Controller. The interface 44 also has a 
connection 46 for control and interrupt signals, and registers 48 which support the RAM 
structure and the operational registers of the host controller 40. 

The interface 44 is connected to the on-chip RAM 50 of the host controller, 
which in this preferred embodiment is a dual port RAM. as will be described in more detail 
10 below. The memory 50 is connected to the host controller logic unit 52, which also contains 
an interface for the USB bus 42. Control signals can be sent fiom the registers 48 to the logic 

unit 52 on an internal bus 54. 

As mentioned above, the on-chip memory 50 in this case is a dual port RAM,, 
allowing data to be written to and read from the memory simultaneously. 
15 Fig. 3 shows an alternative embodiment of the invention, in which common 

reference numerals indicate the same features as in Fig. 2. In this case, the on-chip memory 
56 is a single port RAM, and data written to and read ftom the memory 56 is transferred 
through an arbiter 58, which again allows for effectively simultaneous access to the 
memory 56. 

20 Fig. 4 shows the structure of the on-chip memory. As far as the structure 

shown in Fig. 4 is concerned, this is the same whether the on-chip memory is the dual port 
RAM 50 shown in Fig. 2, or the single port RAM 56 shown in Fig. 3 . 

As shown in Fig. 4, the RAM is effectively divided into two parts, namely a 
first part 70 which contains header and stetus information for the stored transfer descriptors 

25 TDl, TD2, TDn, and which is itself subdivided into a portion 72 relating to as>'nchronous 
(bulk) transfers and a portion 74 relating to periodic (isochronous and interrupt) transfers, and 
a second part 76, which contains the payload data for those stored transfer descriptors TDl. 
TD2 TDn. 

This structure of the RAM has the advantage that the host microprocessor 20 . 
30 can easily %vrite and read all of the transfer descriptor headers together. This strucwre also 
makes it easy for the headers relating to periodic transfers to be scanned only once in each 
micro-frame, while headers relating to asynchronous transfers are scanned continuously 
throughout the micro-frame. 
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This means that the lime bet%veen transactions will be small and, equally 
importantly, it will be consistent from one transaction to another. 

Fig. 5 is a schematic diagram shoNving in part the software operating on the 
host controller 40, in order to illustrate the method of operation of the device according to the 
5 invaition. 

Ths host controller 40 runs USB driver software 80 and USB Enhanced Host 
Controller Interface software 82, which are generally conventional. 

However, in accordance with the present invention, the host controller 40 also 
runs USB EHCI interface software 84, which prepares a Ust of transfer-based transfer 
10 descriptors for every endpoint to which data is to be transmitted. 

The EHCI interface software 84 is written such that it uses the parameters 
which are generated by the EHCI host stack 82 for the existing periodic and asynchronous 
headers, and can be used for all different forms of USB transfer, in particular high speed USB 
transfer, such as high speed isochronous, bulk, interrupt and control and start/stop split 
15 transactions. 

The host microprocessor 20 writes the transfer-based transfer descriptors into 
the RAM 50 or 58 of the host controller 40 through tiie peripheral bus 32, without the host 
controUer 40 requiring to master the bus 32. In other words, the host controller 40 acts only 
as a slave. The transfer-based transfer descriptors can then be memory-mapped into the RAM 

20 50 or 58 of tiie host controller 40. 

Advantageously, the built-in memory 50 or 58 of the host controller 40 is 
mapped in the host microprocessor 20, impromg the ease with which transactions can be 
scheduled from tiie host microprocessor 20. 

Moreover, as described above, the use of a dual-port RAM 50, or a single-port 
25 RAM 56 plus an arbiter 58, means that, while one transfer-based transfer descriptor is being 
executed by the host controller 40. the host microprocessor 20 can be writing data into 

another block space. 

Fig. 6 illustrates the format of one USB frame, divided into multiple micro- 
frames, in which data is transmitted from die host controller 40 over flie USB bus 42. As is 
30 conventional, multiple transactions, including transactions of different transfer types, may be 
sent witiiin one micro-frame. Again, as is conventional, high speed isochronous transfer is 
always first, followed by high speed interrupt transfer, and full speed and low speed Start 
Split and Complete Split transfers, mxti high speed bulk data occupying tiie remaining time 
in the micro-frame. 
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The transfer-based protocol allows the host microprocessor 20 to write a 1ms 
frame of data into the RAM 50 or 58 of the host controller (provided that the RAM is large 
enough to hold this data), such that this can be transmitted over the USB bus 42 without 
further intervention from the host microprocessor. 

5 Fig. 7 illustrates the transfer-based protocol for supporting high-speed USB 

transmissions, with Fig. 7a showing the formal of a 16-byte header of a transfer-based 
transfer descriptor for one endpoint, in accordance with the protocol, and Figs. 7b and 7c 
describing the contents of the header fields. The transfer-based protocol header consists of 
parameter that have the same definition as the conventional USB EHCI software, allowing 

10 die transfer descriptors to be easily constructed. 

The transfer-based protocol also ensures that data can be sent to each USB 

en^int on a fair basis. 

Fig. 8 shows a situation in which the payload data associated with a first 
transfer descriptor TDl is divided into three packets. PLl. PL2 and PL3, each of 64 bytes; 
15 the payload data associated with a second transfer descriptor TD2 comprises just one packet 
PLl of 32 bytes; the payload data associated wth a third transfer descriptor TD3 is divided 
into two packets PLl and PL2, each of 8 bytes; and the payload data associated with a fourth 
transfer descriptor TD4 is divided into fourpackets PLl, PL2, PL3 andPL4, each of 16 
bytes. 

20 Fig. 9 illustrates the method by which these packets of data are transferred out 

of the RAM 50, or 56, to their respective endpoints in respective devices connected to the 
host 

As indicated by the arrow 90 in Fig. 8, a cyclical process occurs. Firstly, in 
step 91 , the first packet PLl associated with the first transfer descriptor TDl is transferred. 
25 The transfer descriptor contains an Active flag which is set high, to indicate that there 
remains more data associated wth this transfer descriptor. 

Secondly5 in step 92. the first packet PLl associated with the second transfer 
descriptor TD2 is transferred. This transfer descriptor now contams an Active flag which is 
set low by the host controller 40, indicating that this completes the transfer of the payload 
30 data associated widi the second transfer descriptor TD2. 

Next, in steps 93 and 94, the first packets PLl of payload data associated with 
the third and fourth transfer descriptors TD3 and TD4 respectively, are transferred. Again, 
each of these transfer descriptors contain an Active flag which is set high, indicating that 
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there is more of the payload data associated with each of the transfer descriptors, remaining 
to be transferred. 

Next, in step 95. the second packet PL2 of payload data associated with the 
first transfer descriptor TD 1 is transferred. The Active flag remains high, because there is still 
5 more of the payload data associated with that transfer descriptor, remaining to be transferred. 

• The transfer of the payload data associated with the second transfer descriptor 
TD2 has been completed, and so, in step 96. the second packet PL2 of payload data 
associated with the third transfer descriptor TD3 is transferred. This time, the Active flag m 
this transfer descriptor is set low. indicating that this completes the transfer of the payload 
10 data associated with the third transfer descriptor TD3. 

In step 97. the second packet PU of payload data associated with the fourth 
transfer descriptor TD4 is transferred, and the Active flag remains high. 

In step 98, the third packet PL3 of payload data associated with the first 
transfer descriptor TDl is transfened, and the Active flag is set low. in^cating that this 
completes the transfer of payload data associated with the first transfer descriptor. 

In steps 99 and 100, the third and fourth packets PL3 and PL4 of payload data 
associated ^^dth the fourth transfer descriptor 1^4 are transmitted, with the Active flag being 
set low in step 100. to indicate that this completes the transfer of the payload data associated 

with die fourth transfer descriptor TD4. 

During execution of the transfer-based transfer descriptors, the content of the 
transfer-based transfer descriptors is updated by the host controller logic unit 52. For 
example, the Active flag within a transfer descriptor header is set low when the transfer of 
the pavload data associated wth the transfer descriptor is completed. The USB EHCI 
interface so^vare 84 then refomiats the updated transfer-based transfer descriptors into a 
25 fomiat which can be handled by the conventional EHCI host stack 82, and the updated 
transfer-based transfer descriptors are copied back to the system memory 30. 

There is therefore pro\ided a host controller which allows the incorporation of 
high speed USB host functionality, in particulat into non-PC based systems. 
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CLAIMS: 



Y A host controller, for use in a bus communication device comprising a host 

microprocessor and a system memory, the host controller comprising: 

a first interface for connection to a memory bus which connects the host 
microprocessor and the system memory, such that the host controller is adapted to act'only as 
5 a slave on the memory bus; 

an internal memory, for storing a plurality of transfer-based transfer 
descriptors received through the first interface; and 

a second interface, for connection to an extemal bus, 
wherein the host controller is adapted to: 
[0 • execute stored transfer-based transfer descriptors; 

update the content of the stored transfer-based transfer descriptors on 
execution; and 

copy the updated stored transfer-based transfer descriptors to the system 

memory. 

15 

. 2. A host controller as claimed in claim 1 , wherein the internal memory is a dual- 

port RAM. 

3^ A host controller as claimed in claim 1 , wherein the internal memory is a 

20 smgle-port RAM, and the host controller further comprises an arbiter to allow data to be 
written to and read firom the RAM essentially simultaneously. 

4, A host controller as claimed in claim 1 , wherein the internal memory is 
divided into two parts, and is adapted to store transfer-based transfer descriptor headers in a 

25 first part, and to store transfer-based transfer descriptor payload data in a second part. 

5. A host controller as claimed in claim 4, wherein the first part of the internal 
memory is sub-divided into two sub-parts, and is adapted to store transfer descriptor headers 
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relating to periodic transfers in a first sub-part, and to store transfer descriptor headers 
relating to asjoichronous transfers in a second sub-part. 

6. . A host controller as claimed in claim 5. wherein the host controller is adapted 
to scan the first sub-part of the internal memory once in each micro-frame, and is adapted to 
scan the second sub-part continuously throughout each micro-frame. 

7. A host controller as claimed in claim I, wherein the host controller is a USB 
host controller and the second interfece is a USB bus interface. 

8. A host controller as claimed in claim 1, wherein the internal memory is 
adapted to store multiple micro-frames of transfer descriptors, and to execute the stored 
transfer descriptors without intervention from the host microprocessor. 

5 9. A host controller as claimed in claim 8, wherein each of the multiple micro- 

frames of transfer descriptors may store payload data relating to one or more of isochronous, 
intermpt and bulk data transfers. 

Abus communication device, comprising: 
20 - a host microprocessor; 

a system manory, 

a memory bus, which connects the host microprocessor and the system 

memory; and 

a host controller, 

25 , wherein the host microprocessor is adapted to form transfer-based transfer 

descriptors, and write the transfer-based transfer descriptors to the system memory and to the 
host controller, and 

wherein the host controller comprises: 

a first interface for connection to the memory bus, such that the host controUer 
30 is adapted to act only as a slave on the memory bus; 

an internal memory, for storing a plurality of transfer-based transfer 
descriptors received through the first interface; and 

a second interface, for connection to an external bus, 
wherein the host controller is adapted to: 
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execute stored transfer-based transfer descriptors; 
^ . update the content of die stored transfer-based transfer descriptors on 

execution; and 

copy the updated stored transfer-based transfer descriptors to the system 

5 memory. 

11. A bus communication de\ice as claimed in claim 1 0, wherein the second 
interface of the host controller is a USB bus interface, and the bus communication device is 
adapted to act as a USB host. 

10 

12. A bus communication deNice as claimed in claim 1 0, wherein the host 
microprocessor is adapted to write a plurality of micro-frames of transfer descriptors to the 
system memory and to the host controller, and the host controller is adapted to execute the 
plurality of micro-frames of transfer descriptors without intervention from the host 

15 microprocessor. 
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ABSTEIACT: 



An electronic device, operating as a USB host, has an embedded processor and 
a system memory, connected by a memory bus. A host controUer integrated circuit does not 
need to master the system memory, but instead acts purely as a slave. The embedded 
processor is then adapted to write the data to the host controller integrated circuit in the fonn 
of transfer-based transactions. 
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